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In this chapter 


» Introduction 


» Structured Query 


“The most important motivation for the Language (SOL) 
research work that resulted in the relational > Date Urnes aad 
model was the objective of providing a sharp Constraints in MySQL 
and clear boundary between the logical and » SQL for Data Definition 
physical aspects of database management.” » SQL for Data 
Manipulation 
—F F. Codd » SQL for Data Query 
l » Data Updation and 
Deletion 


8.1 INTRODUCTION 


We have learnt about Relational Database 
Management System (RDBMS) and purpose in the 
previous chapter. There are many RDBMS such 
as MySQL, Microsoft SQL Server, PostgreSQL, 
Oracle, etc. that allow us to create a database 
consisting of relations and to link one or more 
relations for efficient querying to store, retrieve 
and manipulate data on that database. In this 
chapter, we will learn how to create, populate and 
query database using MySQL. 
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8.2 STRUCTURED QUERY LANGuAGE (SQL) 


One has to write application programs to access data in 
case of a file system. However, for database management 
systems there are special kind of programming 
languages called query language that can be used to 
access data from the database. The Structured Query 
Language (SQL) is the most popular query language 
used by major relational database management systems 
such as MySQL, ORACLE, SQL Server, etc. 

SQL is easy to learn as the statements comprise of 
descriptive English words and are not case sensitive. 
We can create and interact with a database using SQL 
in an efficient and easy way. The benefit with SQL is 
that we don’t have to specify how to get the data from 
the database. Rather, we simply specify what is to be 
retrieved, and SQL does the rest. Although called a query 
language, SQL can do much more besides querying. 
SQL provides statements for defining the structure of 
the data, manipulating data in the database, declare 
constraints and retrieve data from the database in 
various ways, depending on our requirements. 

In this chapter, we will learn how to create a database 
using MySQL as the RDBMS software. We will create a 
database called StudentAttendance (Figure 7.5) that we 
had identified in the previous chapter. We will also learn 
how to populate database with data, manipulate data in 
that and retrieve data from the database through SQL 
queries. 


8.2.1 Installing MySQL 


MySQL is an open source RDBMS software which can 
be easily downloaded from the official website https: / / 
dev.mysql.com/downloads. After installing MySQL, 
start MySQL service. The appearance of mysql> prompt 
(Figure 8.1) means that MySQL is ready for us to enter 
SOL statements. 
Few rules to follow while writing SQL statements in 
MySQL: 
e SQL is case insensitive. That means name and NAME 
are same for SOL. 






Activity 8.1 


Explore LibreOffice 

Base and compare it 

with MySQL e To enter multiline SQL statements, we don’t write 
<’ after the first line. We put enter to continue on 
next line. The prompt mysql> then changes to ‘>’, 


e Always end SQL statements with a semicolon (;). 
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indicating that statement is continued to the next 
line. After the last line, put $’ and press enter. 


8.3 Data TYPES AND CONSTRAINTS IN MySQL 





n F "a e a a a ~ oy ot =) a oe J> 
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nter password: ***** 
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LS ee 


elcome to the MySQL monitor. Commands end with ; or \g. 


our MySQL connection id is 13 
Server version: 5.7.23-log MySQL Community Server (GPL) 









owners. 


sql> 
Figure 8.1: MySQL Shell 


We know that a database consists of one or more 
relations and each relation (table) is made up of attributes 
(column). Each attribute has a data type. We can also 
specify constraints for each attribute of a relation. 


8.3.1 Data type of Attribute 


Data type indicates the type of data value that an 
attribute can have. The data type of an attribute decides 
the operations that can be performed on the data of 
that attribute. For example, arithmetic operations can 
be performed on numeric data but not on character 
data. Commonly used data types in MySQL are numeric 
types, date and time types, and string (character and 
byte) types as shown in Table 8.1. 


opyright (c) 2000, 2018, Oracle and/or its affiliates. All rights reserved. 


racle is a registered trademark of Oracle Corporation and/or its 
affiliates. Other names may be trademarks of their respective 


ype "help; or '\h' for help. Type '\c' to clear the current input statement. 









Activity 8.2 


What are the other 

data types supported in 
MySQL? Are there other 
variants of integer and 
float data type? 


B Think and Reflect 


Can you think of an 
attribute for which 





fixed length string is 
suitable? 


Table 8.1 Commonly used data types in MySQL 





CHAR(n) Specifies character type data of length n where n could be any value from O to 
255. CHAR is of fixed length, means, declaring CHAR (10) implies to reserve 
spaces for 10 characters. If data does not have 10 characters (for example, 
‘city’ has four characters), MySQL fills the remaining 6 characters with spaces 


padded on the right. 


VARCHAR( n) Specifies character type data of length ‘n’ where n could be any value from O 
to 65535. But unlike CHAR, VARCHAR is a variable-length data type. That is, 
declaring VARCHAR (30) means a maximum of 30 characters can be stored 
but the actual allocated bytes will depend on the length of entered string. So 
‘city’ in VARCHAR (30) will occupy the space needed to store 4 characters only. 
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| NT INT specifies an integer value. Each INT value occupies 4 bytes of storage. The 
range of values allowed in integer type are -2147483648 to 2147483647. For 
values larger than that, we have to use BIGINT, which occupies 8 bytes. 


FLOAT Holds numbers with decimal points. Each FLOAT value occupies 4 bytes. 


DATE The DATE type is used for dates in 'YYYY-MM-DD' format. YYYY is the 4 digit 
year, MM is the 2 digit month and DD is the 2 digit date. The supported range 
is '1000-01-01' to '9999-12-31'. 


y e 8.3.2 Constraints 


+ Think and Reflect . . SOE 
=e ; Constraints are certain types of restrictions on the data 
Which two constraints 


when applied together values that an attribute can have. They are used to 

will produce a Primary ensure the accuracy and reliability of data. However, it 

Key constraint? is not mandatory to define constraint for each attribute 
of a table. Table 8.2 lists various SQL constraints. 





Table 8.2 Commonly used SQL Constraints 


NOT NULL Ensures that a column cannot have NULL values where NULL means missing/ 
unknown/not applicable value. 


UNI QUE Ensures that all the values in a column are distinct/unique. 
Dee UE Ip A default value specified for the column if no value is provided. 
PRI MARY KEY The column which can uniquely identify each row or record in a table. 


FOREIGN KEY The column which refers to value of an attribute defined as primary key in another 
table. 


8.4 SQL For Data DEFINITION 


SQL provides commands for defining the relation 
schemas, modifying relation schemas and deleting 
relations. These are called Data Definition Language 
(DDL) through which the set of relations are specified, 
including their schema, data type for each attribute, the 
constraints as well as the security and access related 
authorisations. 

Data definition starts with the create statement. This 
statement is used to create a database and its tables 
(relations). Before creating a database, we should be 
clear about the number of tables in the database, the 
columns (attributes) in each table along with the data 
type of each column. This is how we decide the relation 
schema. 


8.4.1 CREATE Database 


To create a database, we use the CREATE DATABASE 
statement as shown in the following syntax: 
CREATE DATABASE databasename; 
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To create a database called StudentAttendance, we 
will type following command at mysql prompt. 


mysql > CREATE DATABASE Student Attendance; 
Query OK, 1 row affected (0.02 sec) 


Note: In LINUX environment, names for database and tables 
are case-sensitive whereas in WINDOWS, there is no such 
differentiation. However, as a good practice, it is suggested to write 
database or table name in the same letter cases that were used at 
the time of their creation. 


A DBMS can manage multiple databases on one 
computer. Therefore, we need to select the database 
that we want to use. Once the database is selected, we 
can proceed with creating tables or querying data. Write 
the following SQL statement for using the database: 


mysql > USE StudentAttendance: 
Database changed 
Initially, the created database is empty. It can be 
checked by using the Show tables command that lists 
names of all the tables within a database. 


mysql > SHOW TABLES; 
Empty set (0.06 sec) 


8.4.2 CREATE Table 


After creating database StudentAttendance, we need 
to define relations (create tables) in this database and 
specify attributes for each relation along with data types 
for each attribute. This is done using the CREATE TABLE 
statement. 
Syntax: 
CREATE TABLE tabl ename( 


attri butenamel datatype constraint, 
attri butename2 datatype constraint, 


attri butenameN datatype constraint); 


It is important to observe the following points with 

respect to the Create Table statement: 

e N is the degree of the relation, means there are N 
columns in the table. 


e Attribute name specifies the name of the column in 
the table. 

e Datatype specifies the type of data that an attribute 
can hold. 

e Constraint indicates the restrictions imposed on the 
values of an attribute. By default, each attribute can 
take NULL values except for the primary key. 
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Activity 8.3 


Type the statement 
show database;. Does 
it show the name of 
StudentAttendance 
database? 
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Let us identify data types of the attributes of table 
STUDENT along with their constraint, if any. Assuming 
maximum students in a class to be 100 and values of 
roll number in a sequence from 1 to 100, we know that 
3 digits are sufficient to store values for the attribute 
RollNumber. Hence, data type | NT is appropriate for this 
attribute. Total number of characters in student names 
(SName) can differ. Assuming maximum characters in 
a name as 20, we use VARCHAR( 20) for SName column. 
Data type for the attribute SDateofBirth is DATE and 
supposing the school uses guardian’s 12 digit Aadhaar 
number as GUID, we can declare GUID as CHAR( 12) 
since Aadhaar number is of fixed length and we are not 
going to perform any mathematical operation on GUID. 

Table 8.3, 8.4 and 8.5 show the chosen data type and 
constraint for each attribute of the relations STUDENT, 
GUARDIAN and ATTENDANCE, respectively. 


Table 8.3 Data types and constraints for the attributes of relation STUDENT 


Attribute Name Data expected to be stored Data type 


RollNumber Numeric value consisting of maximum 3 digits | NT PRI MARY KEY 
SName Variant length string of maximum 20 characters VARCHAR( 20) NOT NULL 
SDateofBirth Date value DATE NOT NULL 

GUID Numeric value consisting of 12 digits CHAR( 12) FOREIGN KEY 


Table 8.4 Data types and constraints for the attributes of relation GUARDIAN 





Attribute Name Data expected to be stored Data type 


GUID Numeric value consisting of 12 digit Aadhaar CHAR (12) PRI MARY KEY 
number 
GName Variant length string of maximum 20 VARCHAR( 20) NOT NULL 
characters 
GPhone Numeric value consisting of 10 digits CHAR( 10) NULL UNI QUE 
GAddress Variant length string of size 30 characters VARCHAR( 30) NOT NULL 


Table 8.5 Data types and constraints for the attributes of relation ATTENDANCE. 


Attribute Name Data expected to be stored Data type 


AttendanceDate Date value DATE PRI MARY KEY? 
RollNumber Numeric value consisting of maximum 3 | NT PRI MARY KEY* 
digits FOREIGN KEY 

AttendanceStatus ‘P’ for present and ‘A’ for absent CHAR( 1) NOT NULL 


*means part of composite primary key 


Once data types and constraints are identified, let us 
create tables without specifying constraint along with 
the attribute name for simplification. We will learn to 
incorporate constraints on attributes in Section 8.4.4. 
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Example 8.1 Create table STUDENT. I O 





mysql> CREATE TABLE STUDENT( 2’ Think and Reflect 
-> Roll Number INT, Can we have a CHAR 
-> SName VARCHAR( 20), or VARCHAR data type 
- > SDateof Bl rth DATE, for contact number 
-> GUID CHAR( 12), bile. landline)? 
> PRIMARY KEY (Roll Number))- a aaa 


Query OK, 0 rows affected (0.91 sec) 


Note: ‘,’ is used to separate two attributes and each statement 
terminates with a semi-colon (;). The symbol ‘->’ indicates line 
continuation as SQL statement may not complete in a single line. 


8.4.3 DESCRIBE Table 





We can view the structure of an already created table ar eee 
using the describe statement. ees — 
Syntax: as per data types 
DESCRIBE tabl ename; given in Table 8.4 and 
MySQL also supports the short form DESC of DESCRI BE i Ee as aa 
to get description of table. To retrieve details about the any constraint in the 
structure of relation STUDENT, we can write DESC or two tables. 


DESCRI BE followed by table name: 
mysql> DESC STUDENT: 


tee eee eee ee ee re t--------- t------- + 
| Field | Type | Null | Key | Default | Extra | 
tee eee eee eee eee te +e eee eee eee t------ t----- t--------- t------- + 
| Roll Number | int | NO | PRI | NULL | | 
| SName | varchar(20) | YES >| | NULL | | 
| SDateofBirth | date | YES N | NULL | | 
| GUID | char(12) | WY | | NULL | | 
tee eee ee eee eee -erreren -=r t----- t--------- t------- + 


4 rows in set (0.06 sec) 


The show table command will now return the table 


STUDENT: 
mysql > SHOW TABLES; 
tee ee ee ee ee eee eee eee + 
| Tables_in_studentattendance | 
tee eee ee eee ee eee eee + 
| student | 
fee eee ee eee eee eee eee + 


l1 row in set (0.00 Sec) 


8.4.4 ALTER Table 


After creating a table we may realize that we need to 
add/remove an attribute or to modify the datatype of an 
existing attribute or to add constraint in attribute. In all 
such cases, we need to change or alter the structure of 
the table by using the alter statement. 


Syntax: 


ALTER TABLE tablename ADD/ Modif y/DROP attributel, 
attribute2,.. 


2020-21 


Chap 8.indd 149 19-Jul-19 3:45:57 PM 


Chap 8.indd 150 








J’ Think and Reflect 
“Name foreign keys in 
table ATTENDANCE 
and STUDENT. Is there 


any foreign key in table 
GUARDIAN. 


INFORMATICS PRACTICES — CLASS XI 


(A) Add primary key toa relation 

Let us now alter the tables created in Activity 8.4. The 
below MySQL statement adds a primary key to the 
GUARDIAN relation: 


mysql> ALTER TABLE GUARDIAN ADD PRIMARY KEY (GUID); 
Query OK, 0 rows affected (1.14 sec) 
Records: 0 Duplicates: 0 Warnings: 0 
Now let us add primary key to the ATTENDANCE 
relation. The primary key of this relation is a composite 
key made up of two attributes — AttendanceDate and 
RollNumber. 


mysql> ALTER TABLE ATTENDANCE 
-> ADD PRIMARY KEY(AttendanceDate, 
-> Roll Number); 
Query OK, O rows affected (0.52 sec) 
Records: 0 Duplicates: 0 Warnings: 0 


(B) Add foreign key to a relation 

Once primary keys are added the next step is to add 
foreign keys to the relation (if any). A relation may have 
multiple foreign keys and each foreign key is defined on 
a single attribute. Following points need to be observed 
while adding foreign key to a relation: 

e The referenced relation must be already created. 


e The referenced attribute must be a part of primary 
key of the referenced relation. 


e Data types and size of referenced and referencing 
attributes must be same. 
Syntax: 
ALTER TABLE table name ADD FOREIGN KEY( attribute 


name) REFERENCES referenced table name 
(attribute name) ; 


Let us now add foreign key to the table STUDENT. 
Table 8.3 shows that attribute GUID (the referencing 
attribute) is a foreign key and it refers to attribute GUID 
(the referenced attribute) of table GUARDIAN (Table 8.4). 
Hence, STUDENT is the referencing table and GUARDIAN 
is the referenced table. 


mysql > ALTER TABLE STUDENT 
-> ADD FOREIGN KEY( GUID) REFERENCES 
- > GUARDI AN( GUI D); 
Query OK, 0 rows affected (0.75 sec) 
Records: 0 Duplicates: 0 Warnings: 0 


(C) Add constraint UNIQUE to an existing attribute 
In GUARDIAN table, attribute GPhone has a constraint 
UNI QUE which means no two values in that column 
should be same. 

Syntax: 
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ALTER TABLE table name ADD UNI QUE (attribute 
name); 


Let us now add the constraint UNIQUE with attribute 


GPhone of the table GUARDIAN as shown at table 8.4. 
mysql > ALTER TABLE GUARDI AN 
-> ADD UNI QUE( GPhone) ; 
Query OK, O rows affected (0.44 sec) 
Records: 0 Duplicates: 0 Warnings: 0 


(D) Add an attribute to an existing table 
Sometimes, we may need to add an additional attribute 
in a table. It can be done using the syntax given below: 


ALTER TABLE table name ADD attribute name DATATYPE: 


Suppose the principal of the school has decided to 
award scholarship to some needy students for which 
income of the guardian must be known. But school has 
not maintained income attribute with table GUARDIAN 
so far. Therefore, the database designer now needs to 
add a new attribute income of data type INT in the table 
GUARDIAN. 


mysql> ALTER TABLE GUARDI AN 
-> ADD income | NT; 
Query OK, O rows affected (0.47 sec) 
Records: 0 Duplicates: 0 Warnings: 0 
(E) Modify datatype of an attribute 
We can modify data types of the existing attributes of a 
table using the following ALTER statement. 


Syntax: 
ALTER TABLE table name MODIFY attribute DATATYPE: 


Suppose we need to change the size of attribute 
GAddress from VARCHAR(30) to VARCHAR(40) of the 
GUARDIAN table. The MySQL statement will be: 


mysql > ALTER TABLE GUARDI AN 

-> MODIFY GAddress VARCHAR( 40) ; 
Query OK, O rows affected (0.11 sec) 
Records: 0 Duplicates: 0 Warnings: 0 


(F) Modify constraint of an attribute 

When we create a table, by default each attribute takes 
NULL value except for the attribute defined as primary 
key. We can change an attribute’s constraint from NULL 
to NOT NULL using alter statement. 

Syntax: 


ALTER TABLE table name MODIFY attribute DATATYPE 
NOT NULL; 


Note: We have to specify the data type of the attribute along with 
constraint NOT NULL while using MODI FY. 
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Activity 8.5 


Add foreign Key in 

the ATTENDANCE 
table (use fig. 8.1 to 
identify referencing and 
referenced tables). 


oes, 
e= 
= 
== 
= 


What are the minimum 
and maximum income 
values that can be 





entered in the income 
attribute given the data 
type is | NT? 


? Think and Reflect 
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To associate NOT NULL constraint with attribute 


SName of table STUDENT (table 8.3), we write the 
following MySQL statement: 


mysql> ALTER TABLE STUDENT 

-> MODIFY SName VARCHAR( 20) NOT NULL: 
Query OK, 0 rows affected (0.47 sec) 
Records: 0 Duplicates: 0 Warnings: 0 


(G) Add default value to an attribute 
If we want to specify default value for an attribute, then 
use the following syntax: 
ALTER TABLE table name MODIFY attribute DATATYPE 
DEFAULT default_value; 
To set default value of SDateofBirth of STUDENT to 
15th May 2000, we write the following statement: 


mysql > ALTER TABLE STUDENT 
-> MODIFY SDateof Birth DATE DEFAULT 
-> 2000-05-15; 
Query OK, 0 rows affected (0.08 sec) 
Records: 0 Duplicates: 0 Warnings: 0 


Note: We have to specify the data type of the attribute along with 
DEFAULT while using MODI FY. 


(H) Remove an attribute 
Using ALTER, we can remove attributes from a table, as 
shown in the below syntax: 

ALTER TABLE table name DROP attri bute; 


To remove the attribute income from the table 
GUARDIAN (8.4), we can write the following MySQL 
statement: 


mysql > ALTER TABLE GUARDIAN DROP income; 

Query OK, 0 rows affected (0.42 sec) 

Records: 0 Duplicates: 0 Warnings: 0 
(I) Remove primary key from the table 
While creating a table, we may have specified incorrect 
primary key. In such case, we need to drop the existing 
primary key of the table and add a new primary key. 

Syntax: 
ALTER TABLE table name DROP PRIMARY KEY; 


To remove primary Key of table GUARDIAN (Table 8.4), 
we write the following MySQL statement: 
mysql > ALTER TABLE GUARDIAN DROP PRIMARY KEY; 


Query OK, 0 rows affected (0.72 sec) 
Records: 0 Duplicates: 0 Warnings: 0 


Note: We have dropped primary key from GUARDIAN table, but 
each table should have a primary key to maintain uniqueness. 
Hence, we have to use ADD command to specify primary key for 
the GUARDIAN table as shown in earlier examples. 
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8.4.5 DROP Statement 


Sometimes a table in a database or the database itself 
needs to be removed. We can use DROP statement to 
remove a database or a table permanently from the 
system. However, one should be very cautious while 
using this statement as it cannot be undone. 


Syntax to drop a table: 
DROP TABLE table name; 


Syntax to drop a database: 
DROP DATABASE database name; 


Cautions: 
1) Using the Drop statement to remove a database will 
ultimately remove all the tables within it. 


2) DROP statement will remove the tables or database 
created by you. Hence you may apply DROP statement at 
the end of the chapter. 


8.5 SQL For Data MANIPULATION 


In the previous section, we created the database 
StudentAttendance having three relations STUDENT, 
GUARDIAN and ATTENDANCE. When we create a table, 
only its structure is created but the table has no data. 
To populate records in the table, | NSERT statement is 
used. Similarly, table records can be deleted or updated 
using SQL data manipulation statements. 

Data Manipulation using a database means either 
retrieval (access) of existing data, insertion of new data, 
removal of existing data or modification of existing data 
in the database. 


8.5.1 INSERTION of Records 


INSERT I NTO statement is used to insert new records in 
a table. Its syntax is: 

[INSERT INTO tabl ename 

VALUES( Value 1, ValU@ Zar... ) ; 

Here, value 1 corresponds to attribute 1, value 2 
corresponds to attribute 2 and so on. Note that we need 
not to specify attribute names in insert statement if 
there are exactly same number of values in the | NSERT 
statement as the total number of attributes in the table. 


Caution: While populating records in a table with foreign 
key, ensure that records in referenced tables are already 
populated. 
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Let us insert some records in the Student Attendance 
database. We shall insert records in the GUARDIAN 
table first as it does not have any foreign key. We are 
going to insert the records given in Table 8.6. 


Table 8.6 Records to be inserted into the GUARDIAN table 
Fu | GName | GPhone | GAddress O O O 
444444444444 Amit Ahuja 9711492685 G-35, Ashok Vihar, Delhi 
111111111111 Baichung Bhutia 7110047139 Flat no. 5, Darjeeling Appt., Shimla 
101010101010 Himanshu Shah 9818184855 26/77, West Patel Nagar, Anmedabad 
33333333923 Danny Dsouza S -13, Ashok Village, Daman 


4060444444666 Sujata P. 7802983674  HNO-13, B- block, Preet Vihar, Madurai 


The below statement inserts the first record in the 
table. 


mysql > INSERT | NTO GUARDI AN 
-> VALUES (444444444444, ‘Amt Ahuja', 
-> 5711492685, ‘'G-35, Ashok vihar, Delhi’: ); 
Query OK, 1 row affected (0.01 sec) 
We can use the SQL statement SELECT * fromtable_ 
name to view the inserted records. The SELECT statement 
will be explained in next section. 


mysql> SELECT * from GUARDI AN; 


te --- +e 2-2 eee te - eee eee ee eee eee tes - eee eee tee ee ee eee eee eee eee + 
| GUID | GName | Gphone | GAddress | 
te +--+ eee seers te +e eee ee eee eee te -- eee eee tee eee ee ee ee eee ee eee + 
| 444444444444 | Amt Ahuja | 5711492685 | G-35, Ashok vihar, Delhi | 
te --- eee eee eee te - ee eee eee eee eee t-- +--+ eee ee- tee eee ee ee ee ee eee ee eee + 


l1 row in set (0.00 sec) 


If we want to provide values only for some of the 
attributes in a table (supposing other attributes having 
NULL or any other default value), then we shall specify 
the attribute name alongside each data value as shown 
in the following syntax of | NSERT | NTO statement. 

Syntax: 

INSERT INTO tablename (columnil, column2, ...) 
VALUES (valuel, value2, ...); 

To insert the fourth record of Table 8.6 where GPhone 
is not given, we need to insert values in the other three 
fields (GPhone was set to NULL by default at the time 

S _— of table creation). In this case, we have to specify the 
sI names of attributes in which we want to insert values. 
eee The values must be given in the same order in which 
attributes are written in | NSERT command. 


Write SQL statements 
to insert the remaining 


3 rows of table 8.6 in mysql > INSERT INTO GUARDI AN( GUID, GName, GAddress) 
table GUARDIAN. -> VALUES (333333333333, ‘Danny Dsouza', 
2020-21 
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-> 'S -13, Ashok Village, Daman' ); 
Query OK, 1 row affected (0.03 sec) 


Note: Text and date values must be enclosed in ‘’ (single quotes). 
mysql> SELECT * from GUARDI AN; 


tee eee ee eee eee te +--+ eee eee eee t---- 2-2 ee ee- tee ee ee ee eee eee ee eee + 
| GUID | GName | Gphone | GAddress | 
tee eee eee eee eee t--- 25-2 ee ee eee t-------- eee tee eee eee ee ee eee ee eee + 
| 333333333333 | Danny Dsouza | NULL | S -13, Ashok Village, Daman | 
| 444444444444 | Amit Ahuja | 5711492685 | G-35, Ashok vihar, Delhi | 
tee eee ee eee eee te --- eee eee eee t---- 2+ eee eee tee eee ee ee ee eee ee eee + 


2 rows in set (0.00 sec) 


Let us now insert the records given in Table 8.7 into 
the STUDENT table. 


Table 8.7 Records to be inserted into the STUDENT table 


RollNumber | SName | SDateofBirth GUID 


1 Atharv Ahuja 2003-05-15 444444444444 
2 Daizy Bhutia 2002-02-28 CEE ae 
3 Taleem Shah 2002-02-28 

4 John Dsouza 2003-08-18 239222 
5 Ali Shah 2003-07-05 101010101010 
6 Manika P. 2002-03-10 466444444666 


To insert the first record of Table 8.7, we write the 
following MySQL statement 


mysql> INSERT | NTO STUDENT 
-> VALUES(1,'Atharv Ahuja','2003-05-15', 
-> 444444444444) ; 

Query OK, 1 row affected (0.11 sec) 


OR 


mysql> INSERT INTO STUDENT (Rol! Number, SName, 
-> SDateofBirth, GUID) 
-> VALUES (1,'Atharv Ahuja','2003-05-15', 
-> 444444444444) ; 

Query OK, 1 row affected (0.02 sec) 


mysql> SELECT * from STUDENT; 


te - eee e eee tee - eee eee eee t-- +e eee eee eee t---- eee ee ee eee + 
| Roll Number | SName | SDateofBirth | GUID | 
t----- eee eee tes +e eee eee eee t-- ++ eee eee eee t---- eee ee ee eee + 
| 1 | Atharv Ahuja | 2003-05-15 | 444444444444 | 
t---- eee eee tee eee eee eee eee t----- eee ee eee t-- 2-2 eee eee eee + 


l row in set (0.00 sec) 


Let us now insert the third record of Table 8.7 where 
GUID is NULL. Recall that GUID is foreign key of this Recall that Date is 
table and thus can take NULL value. Hence, we can put —_— a 
NULL value for GUID and insert the record by using the ) 
following statement: 
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mysql > INSERT INTO STUDENT 
-> VALUES(3, ' Taleem Shah' ,'2002-02-28', 
-> NULL): 

Query OK, 1 row affected (0.05 sec) 


mysql > SELECT * from STUDENT; 


t-- ++ eee eee tes eee eee eee eee t-- ++ ee ee eee eee t---- 2 eee eee eee + 
| Roll Number | SName | SDateofBirth | GUID | 
t-- + -e eee eee tee eee eee eee eee t-- ++ eee ee ee eee t-- 2-2 e ee ee eee + 
| 1 | Atharv Ahuja | 2003-05-15 | 444444444444 | 
| 3 | Taleem Shah | 2002-02-28 | NULL | 
tee +e eee eee tee eee eee eee eee t-- + - eee eee eee t---- 22 eee ee eee + 


2 rows in set (0.00 sec) 






Write SQL statements 
to insert the remaining 
4 rows of table 8.7 in 
table STUDENT. 





We had to write NULL in the above MySQL statement 
because when not giving the column names, we need 
to give values for all the columns. Otherwise, we have 
to give names of attributes along with the values if we 
need to insert data only for certain attributes, as shown 
in the next query: 

mysql> INSERT INTO STUDENT (Rol! Number, SName, 
-> SDateof Birth) VALUES (3, ‘Taleem Shah’ ,' 
-> 2002-02-28'); 
Query OK, 1 row affected (0.05 sec) 
In the above statement we are informing DBMS 
to insert the corresponding values for the mentioned 
columns and GUID would be assigned NULL value. 


mysql > SELECT * from STUDENT; 


assessorn -erreren t-- eee eee eee t---- eee eee eee + 
| Roll Number | SName | SDateofBirth | GUID | 
t-- ++ eee eee te - eee eee eee t-- +e eee eee eee t-- 2-2 eee eee eee + 
| 1 | Atharv Ahuja | 2003-05-15 | 444444444444 | 
| 3 | Taleem Shah | 2002-02-28 | NULL | 
-serrare tee eee ee eee eee t-- +e eee eee eee t--- +2 eee eee eee + 


2 rows in set (0.00 sec) 


? Think and Reflect 


e Which of the above 
syntax should be 
used when we are 
not sure of the order 
(with respect to the 
column) in which 


the values are to be 
inserted in the table? 


e Can we insert two 
records with the 
same roll number? 


8.6 SQL For DATA QUERY 


So far we have learnt how to create database as well 
as to store and manipulate data. We are interested to 
store data in a database as it is easier to retrieve data 
in future from databases in whatever way we want. 
The Structured Query Language (SQL) has efficient 
mechanisms to retrieve data stored in multiple tables 
in a MySQL database (or any other RDBMS). The 
user enters the SQL commands called queries where 
the specific requirements for data to be retrieved are 
provided. The SQL statement SELECT is used to retrieve 
data from the tables in a database and is also called 
query statement. 
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8.6.1 SELECT Statement 


The SQL statement SELECT is used to retrieve data from 
the tables in a database and the output is also displayed 
in tabular form. 


Syntax: 
SELECT attributel, attribute2, 
FROM table name 
WHERE condition 
Here, attributel, attribute2, ... are the column names 
of the table table name from which we want to retrieve 
data. The FROM clause is always written with SELECT 
clause as it specifies the name of the table from which 
data is to be retrieved. The WHERE clause is optional and 
is used to retrieve data that meet specified condition(s). 


Example 8.2 To display the name and date of birth of student 
with roll number 2, we write the following query: 


mysql> SELECT SName, SDateof Birth 
-> FROM STUDENT 
-> WHERE Roll Number = 1; 


tes eee ee ee ee eee tee +e ee eee ee eee + 
| SName | SDateofBirth | 
tee eee ee ee ee eee t-- + eee ee ee eee + 
| Atharv Ahuja | 2003-05-15 | 
te - +e eee eee eee t---- eee eee eee $ 


l1 row in set (0.03 sec) 


8.6.2 QUERYING using Database OFFICE 


Different organisations maintain databases to 
store data in the form of tables. Let us consider the 
database OFFICE of an organisation that has many 
related tables like EMPLOYEE, DEPARTMENT and 
so on. Every EMPLOYEE in the database is assigned 
to a DEPARTMENT and his/her Department number 
(DeptId) is stored as a foreign key in the table EMPLOYEE. 
Let us consider some data for the table EMPLOYEE’ as 
shown in Table 8.8 and apply the SELECT statement to 
retrieve data: 


Table 8.8 EMPLOYEE 


101 D02 


Aaliya 10000 234 
102 Kritika 60000 Zs DO1 
103 Shabbir 45000 566 DO1 
104 Gurpreet 19000 965 D04 
105 Joseph 34000 875 DO3 
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Can you think of 
examples from daily 
life where storing 


and querying data 
in a database can be 
helpful? 
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NOTES 106 Sanya 48000 695 D02 
107 Vergese 15000 DO1 
108 Nachaobi 29000 DOS 
109 Daribha 42000 D04 
110 Tanya 50000 467 DOS 


(A) Retrieve selected columns 
The following query displays employee numbers of all 
the employees: 


mysql> SELECT EmpNo 
-> FROM EMPLOYEE; 


m 
3 
-5 
= 
oO 


+ 
| | 
| | 
| | 
| | 
| | 
| 106 | 
| | 
| | 
| | 
| | 

+ 


10 rows in- set (0.41 sec) 


To display the employee number and employee name 
of all the employees, we write the following query: 


mysql > SELECT EmpNo, Ename 
-> FROM EMPLOYEE; 


t-+-+--- t--- +22 --- + 
| EmpNo | Ename | 
t------- t--- +--+ ---- + 
| 101 | Aaliya | 
| 102 | Kritika | 
| 103 | Shabbir | 
| 104 | Gurpreet | 
| 105 | Joseph | 
| 106 | Sanya | 
| 107 | Vergese_ | 
| 108 | Nachaobi | 
| 109 | Daribha | 
| 110 | Tanya | 
t------- t--- 2-22 --- + 


10 rows in set (0.00 sec) 


(B) Renaming of columns 
In case we want to rename any column while displaying 
the output, we can do so by using alias 'AS' in the 
query as: 
Display Employee name as Name in the output for 
all the employees. 
mysql> SELECT EName AS Name 
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-> FROM EMPLOYEE: NOTES 


| | 
| Gurpreet | 
| Joseph | 
| Sanya | 
| Vergese | 
| Nachaobi | 
| Daribha | 
| Tanya | 
+ 


10 rows in set (0.00 sec) 


Example 8.3 Display names of all employees along with their 
annual salary (Salary*12). While displaying query result, 
rename EName as Name. 


mysql> SELECT EName AS Name, Salary*12 
-> FROM EMPLOYEE; 
+ 


ee ee 
| Name | Salary*12 | 
t---------- te -- eee eee + 
Aaliya 120000 
Kritika 720000 
Shabbir 540000 
Gurpreet 228000 
Joseph 408000 
Sanya 576000 
Vergese 180000 
Nachaobl 348000 
Daribha 504000 
Tanya 600000 
t---------- te -- eee eee + 


10 rows in set (0.02 sec) 


Observe that in the output, Salary*12 is displayed as 
the column name for the annual salary column. In the 
output table, we can use alias to rename that column as 
Annual Salary as shown below: 


mysql> SELECT Ename AS Name, Salary*12 AS 
-> ‘Annual Salary’ 
-> FROM EMPLOYEE; 


t---------- te - 2 eee ee eee eee 
| Name | Annual Salary | 
Aaliya 120000 
Kritika 720000 
Shabbir 540000 
Gurpreet 228000 
Joseph 408000 
Sanya 576000 
Vergese 180000 
Nachaobl 348000 
Daribha 504000 
Tanya 600000 
i + 


+ 
10 rows in set (0.00 sec) 
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NoTES Note: 


i) Annual Salary will not be added as a new column in the 
database table. It is just for displaying the output of the 


query. 


ii) If an aliased column name has space as in the case of Annual 
Salary, it should be enclosed in quotes as 'Annual Salary’. 


(C) DISTINCT Clause 

By default, SQL shows all the data retrieved through 
query as output. However, there can be duplicate values. 
The SELECT statement when combined with DI STI NCT 
clause, returns records without repetition (distinct 
records). For example, while retrieving employee’s 
department number, there can be duplicate values as 
many employees are assigned to same department. To 
display unique department number for all the employees, 
we use DI STI NCT as shown below: 


mysql> SELECT DISTINCT Deptid 
-> FROM EMPLOYEE: 


t-------- + 
| Deptid | 
t-------- + 
| D02 | 
| D01 | 
| D04 | 
| D03 | 
| D05 | 
t-------- + 


5 rows in set (0.03 sec) 


(D) WHERE Clause 

The WHERE clause is used to retrieve data that meet 
some specified conditions. In the OFFICE database, 
more than one employee can have the same salary. To 
display distinct salaries of the employees working in the 
department number DO1, we write the following query 
in which the condition to select the employee whose 
department number is DO1 is specified using the WHERE 


clause: 
mysql> SELECT DISTINCT Salary 
-> FROM EMPLOYEE 
-> WHERE Deptid='D01'; 


As the column Deptld is of string type, its values are 
enclosed in quotes ('DO1'). 


t-------- + 
| Salary | 
t-------- + 
| 60000 | 
| 45000 | 
| 15000 | 
t-------- + 


3 rows in set (0.02 sec) 
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In the above example, we have used = operator in 
WHERE clause. We can also use other relational operators 
(<, <=, >, >=, !=) to specify conditions. The logical 
operators AND, OR, and NOT are used with WHERE clause 
to combine multiple conditions. 


Example 8.4 Display all the employees who are earning more 
than 5000 and work in department with DeptId D04. 


mysql> SELECT * 


-> FROM EMPLOYEE 

-> WHERE Salary > 5000 AND Deptid = 'D04'; 
t------- t--- 2-2 ee t-------- t------- t-------- + 
| EmpNo | Ename | Salary | Bonus | Deptlid | 
t------- t---------- t-------- t------- t-------- + 
| 104 | Gurpreet | 19000 | 565 | D04 | 
| 109 | Daribha | 42000 | NULL | DO4 | 
t------- t---------- t-------- t------- t-------- + 
2 rows in set (0.00 sec) 


Example 8.5 The following query displays records of all the ‘ 


employees except Aaliya. 
mysql > SELECT * 


-> FROM EMPLOYEE 
-> WHERE NOT Ename = 'Aaliya': 


t------- t---------- t-------- t------- t-------- + 
| EmpNo | Ename | Salary | Bonus | Deptld | 
t------- H-ren t-------- t---+--- t-------- + 
| 102 | Kritika | 60000 | 123 ,(7)¥1 | 
| 103 | Shabbir | 45000 | 566 | D01 | 
| 104 | Gurpreet | 19000 | 565 | D04 | 
| 105 | Joseph | 34000 | 875 | D03 | 
| 106 | Sanya | 48000 | 695 | D02 | 
| 107 | Vergese | 15000 | NULL | DOI | 
| 108 | Nachaobi | 29000 | NULL | DO5 | 
| 109 | Daribha | 42000 | NULL | D04 | 
| 110 | Tanya | 50000 | 467 | DO5 | 
t------- t---------- t-------- t------- t-------- + 
9 rows in set (0.00 sec) 


Example 8.6 The following query displays name and 
department number of all those employees who are earning 
salary between 20000 and 50000 (both values inclusive). 


mysql> SELECT Ename, Deptid 
-> FROM EMPLOYEE 
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- > WHERE 
t--- 2-2 ---- + 
| Ename | 
t---------- + 
| Shabbir | 
| Joseph | 
| Sanya | 
| Nachaobi | 
| Daribha | 
| Tanya | 
t---------- + 
6 rows in se 


Sal ary>=20000 AND Salary<=50000: 


t (0.00 sec) 
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a Think and Reflect 


What will happen if 

in the above query 

we write “Aaliya” as 
“AALIYA” or “aaliya” 

or “AaLIYA”? Will the 
query generate the same 
output or an error? 


Activity 8.8 


Compare the output 
produced by the query 
in example 8.6 and 
the following query 
and differentiate 
between the OR and AND 


operators. 
SERECI 7 
FROM EMPLOYEE 
WHERE Salary > 5000 OR 
Deptil d= 20; 
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The above query defines a range that can also be 
checked using a comparison operator BETWEEN. 


mysql> SELECT Ename, Deptld 
-> FROM EMPLOYEE 
-> WHERE Salary BETWEEN 20000 AND 50000; 


t---------- t-------- + 

| Ename | Deptid | 

t---------- t-------- + 
Shabbir D01 
Joseph D03 
Sanya D02 


Nachaobi D05 

Dari bha D04 

Tanya DOS 
+ 


+ 
6 rows in set (0.03 sec) 
Note: The BETWEEN operator defines the range of values in which 
the column value must fall into, to make the condition true. 


Example 8.7 The following query displays details of all the 
employees who are working either in DeptId D01, DO2 or 
D04. 


mysql> SELECT * 
-> FROM EMPLOYEE 
-> WHERE Deptid = 'D01' OR Deptld = 'D02' OR 
-> Deptild = ' D04"; 


t------- t-- 25 ------ t-------- t------- t-------- + 
| EmpNo | Ename | Salary | Bonus | Deptlid | 
t------- t------5--- t-------- t------- t-------- + 

101 Aaliya 10000 234 D02 

102 Kritika 60000 123 D01 

103 Shabbir 45000 566 DO1 

104 Gurpreet 19000 565 D04 

106 Sanya 48000 695 D0? 

107 Vergese 15000 NULL DOI 

109 Dari bha 42000 NULL D04 
t------- t---------- t-------- t------- t-------- + 


7 rows in set (0.00 sec) 


(E) MEMBERSHIP OPERATOR IN 

The | N operator compares a value with a set of values 
and returns true if the value belongs to that set. The 
above query can be rewritten using |N operator as 
shown below: 


mysql> SELECT * 
-> FROM EMPLOYEE 


-> WHERE Deptild IN ('D01', ‘'DO2' , 'DO04'); 
t------- t---------- t-------- t------- t-------- + 
| EmpNo | Ename | Salary | Bonus | Deptlid | 
t------- t---------- t-------- t------- t-------- + 

101 Aaliya 10000 234 D02 

102 Kritika 60000 123 D01 

103 Shabbir 45000 566 D01 

104 Gurpreet 19000 505 D04 

106 Sanya 48000 695 D02 

107 Vergese 15000 NULL D01 

109 Dari bha 42000 NULL D04 
t------- t---------- t-------- t------- t-------- + 


7 rows in set (0.00 sec) 
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Example 8.8 The following query displays details of all the NOTES 
employees except those working in department number D01 
or DO2. 

mysql> SELECT * 


-> FROM EMPLOYEE 
-> WHERE Deptild NOT IN('D01', 'D02'); 


t------- t- +--+ +2 --- t-------- t------- t-------- + 
| EmpNo | Ename | Salary | Bonus | Deptlid | 
t------- t--- 2-2 ee t-------- t------- t-------- + 
| 104 | Gurpreet | 19000 | 565 | D04 | 
| 105 | Joseph | 34000 | 875 | D03 | 
| 108 | Nachaobi | 29000 | NULL | DO5 | 
| 109 | Daribha | 42000 | NULL | D04 | 
| 110 | Tanya | 50000 | 467 | DO5 | 
t------- t--- 22-2 ee t-------- t------- t-------- + 


5 rows in set (0.00 sec) 


Note: Here we need to combine NOT with | N as we want to retrieve 
all records except with DeptId DO1 and DO2. 


(F) ORDER BY Clause 

ORDER BY clause is used to display data in an ordered 
(arranged) form with respect to a specified column. By 
default, ORDER BY displays records in ascending order of 
the specified column ’s values. To display the records in 
descending order, the DESC (means descending) keyword 
needs to be written with that column. 


Example 8.9 The following query displays details of all the 
employees in ascending order of their salaries. 
mysql> SELECT * 


-> FROM EMPLOYEE 
-> ORDER BY Salary; 


t------- t--- 2-2 --- +--+ 25 --- t------- t-------- + 
| EmpNo | Ename | Salary | Bonus | Deptlid | 
t------- t--- 22-2 --- t-------- t------- t-------- + 
| 101 | Aaliya | 10000 | 234 | D02 | 
| 107 | Vergese | 15000 | NULL | DOI | 
| 104 | Gurpreet | 19000 | 565 | D04 | 
| 108 | Nachaobi | 29000 | NULL | DO5 | 
| 105 | Joseph | 34000 | 875 | DOJ | 
| 109 | Daribha | 42000 | NULL | D04 | 
| 103 | Shabbir | 45000 | 566 | D01 | 
| 106 | Sanya | 48000 | 695 | D02 | 
| 110 | Tanya | 50000 | 467 | DO5 | 
| 102 | Kritika | 60000 | 123 | DOl | 
t------- t--- 22-2 -e- +--+ ----- +--+ ----- t-------- + 


10 rows in set (0.05 sec) 


Example 8.10 The following query displays details of all the 
employees in descending order of their salaries. 


Woa SELECT 7 
-> FROM EMPLOYEE 
-> ORDER BY Salary DESC; 
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t------- i t------- fe +22 --- 
| EmpNo | Ename | Salary | Bonus | Deptlid | 
t------- t--- 2-2-2 ee fee ee eee t-------f- 2-2-2 -- + 

102 Kritika 60000 123 DQ 1 

110 Tanya 50000 467 D05 

106 n 48000 695 D02 

103 Shabbir 45000 5 6 6 DQ 1 

109 Dari bha 42000 NULL D04 

105 joer os | 34000 875 D0 3 

108 achaobl 29000 NULL D03 

104 Gurpreet 19000 565 D04 

107 Vergese 15000 NULL D01 

101 Aaliya 10000 234 D02 
t------- t---------- t-------- t------- t-------- + 
10 rows in set (0.00 sec) 


(G) Handling NULL Values 

SQL supports a special value called NULL to represent 
a missing or unknown value. For example, the village 
column in a table called address will have no value for 
cities. Hence, NULL is used to represent such unknown 
values. It is important to note that NULL is different 
from O (zero). Also, any arithmetic operation performed 
with NULL value gives NULL. For example: 5 + NULL = 
NULL because NULL is unknown hence the result is also 
unknown. In order to check for NULL value in a column, 
we use!5 NULL. 






Activity 8.9 


Execute the following 
two queries and find 
out what will happen if 


Example 8.11 The following query displays details of all 
those employees who have not been given a bonus. This 

















we specify two columns implies that the bonus column will be blank. 
in the ORDER BY clause: mX&a > SBLECT * 
ees -> FROM EMPLOYEE 
aa meaner -> WHERE Bonus |S NULL; 
ORDER VB ES aan Ty NSF - - pee a ae eeenaes pee a eee e aol ay t-------- + 
Bonus: | EmpNo | Ename | Salary | Bonus | Deptid | 

he ee fee eee ee eee feeeeeeee feriae fo saeara + 
SELECT * 107 | Vergese 15000 NULL | DO1 
FROM EMPLOYEE 108 | Nachaobdl 29000 NULL | DOS 

109 | Daribha 42000 NULL | D04 

ORDER BY Salary, Bonus Se ia es Gers th, Jan hie et Sey tee Sieve are i ae senate Aha sh Bie Bea 4 
desc, 3 rows in set (0.00 sec) 


Example 8.12 The following query displays names of all the 
employees who have been given a bonus. This implies that 
the bonus column will not be blank. 


mysql> SELECT EName 
-> FROM EMPLOYEE 
-> WHERE Bonus IS NOT NULL: 


Gurpreet 
Joseph 
Sanya 
Tanya 


+ 
7 rows in set (0.00 sec) 
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(H) Substring pattern matching NOTES 
Many a times we come across situations where we don’t 
want to query by matching exact text or value. Rather, we 
are interested to find matching of only a few characters 
or values in column values. For example, to find out 
names starting with ‘T’ or to find out pin codes starting 
with ‘60’. This is called substring pattern matching. 
We cannot match such patterns using = operator as 
we are not looking for exact match. SQL provides LI KE 
operator that can be used with WHERE clause to search 
for a specified pattern in a column. 
The LIKE operator makes use of the following two 
wild card characters: 
e % (percent)— used to represent zero, one, or multiple 
characters 
e _ (underscore)— used to represent a single character 


Example 8.13 The following query displays details of all those 
employees whose name starts with 'K'. 


mysql> SELECT * 


-> FROM EMPLOYEE 
-> WHERE Ename LIKE 'K%': 


t------- t--------- t-------- t------- treo + 
| EmpNo | Ename | Salary | Bonus | Deptid | 
t------- t--------- t-------- e + 
| 102 | Kritika | 60000 | 123 | D01 | 
t------- t--------- t-------- +--+ -+-- t-------- + 


l row in set (0.00 Sec) 


Example 8.14 The following query displays details of all 
those employees whose name ends with ‘a’. 
Mycal> SELECT 7 


-> FROM EMPLOYEE 
-> WHERE Ename LIKE ' %a': 


t------- t--------- t-------- t------- t-------- + 
| EmpNo | Ename | Salary | Bonus | Deptlid | 
t------- t--------- t-------- t------- t-------- + 

101 Aaliya 10000 234 D02 

102 Kritika 60000 Lo D01 

106 Sanya 48000 695 D02 

109 Dari bha 42000 NULL D04 

110 Tanya 50000 467 D05 


t------- t--------- t-------- t------- t-------- + 
5 rows in set (0.00 sec) 


Example 8.15 The following query displays details of all 
those employees whose name consists of exactly 5 letters 
and starts with any letter but has ‘ANYA’ after that. 


mysql> SELECT ~ 
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-> FROM EMPLOYEE 
-> WHERE Ename LIKE ' ANYA'; 





"When we type first letter ele ele elena Sei i ek Se 
of a contact name in | 106 | Sanya | 48000 | 695 | D02 | 
our contact list in our | 110 | Tanya | 50000 | 467 | DO5 | 
mobile phones all the hessa eee fod aes Wore we ap-ecee a r EEE Jenda eee 4 
names containing that 2 rows in set (0.00 sec) 


character are displayed. 


Example 8.16 The following query displays names of all the 
employees containing 'se' as a substring in name. 


Can you relate SQL 
statement with the 


process? List other real mysql> SELECT Ename 
life situations where you -> FROM EMPLOYEE 
can visualize an SQL -> WHERE Ename LIKE ‘| %se%' ; 
statement in operation. pos ae ae t 
| Ename | 
Patera aa ee + 
| Joseph | 
| Vergese | 
Pa dias a + 


2 rows in set (0.00 sec) 


Example 8.17 The following query displays names of all 
employees containing 'a' as the second character. 
mysql> SELECT- EName 


-> FROM EMPLOYEE 
-> WHERE Ename LIKE ' a%'; 


t----255--- + 
| EName | 
te ++ ----- + 
| Aaliya | 
| Sanya | 
| Nachaobi | 
| Daribha | 
| Tanya | 
t----+----- + 


5 rows in set (0.00 sec) 


8.7 Data UPDATION AND DELETION 


Updation and deletion of data are also the parts of SQL 
data manipulation. In this section, we are going to apply 
these two data manipulation methods. 


8.7.1 Data Updation 


We may need to make changes in the value(s) of one or 
more columns of existing records in a table. For example, 
we may require some changes in address, phone number 
or spelling of name, etc. The UPDATE statement is used to 
make such modifications in the existing data. 

Syntax: 


UPDATE table name 
SET attributel = valuel, attribute2 = value2, 
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WHERE condition: 


The STUDENT Table 8.7 has NULL value for GUID 
for student with roll number 3. Also, suppose students 
with roll numbers 3 and 5 are siblings. So, in STUDENT 
table, we need to fill the GUID value for student with 
roll number 3 as 101010101010. In order to update or 
change GUID of a particular row (record), we need to 
specify that record using WHERE clause, as shown below: 

mysql > UPDATE STUDENT 
-> SET GUID = 101010101010 
-> WHERE Roll Number = 3; 


Query OK, 1 row affected (0.06 sec) 
Rows matched: 1 Changed: 1 Warnings: 0 


We can then verify the updated data using the 
statement SELECT * FROM STUDENT. 


Caution : If we miss the where clause in the UPDATE statement then 
the GUID of all the records will be changed to 101010101010. 


We can also update values for more than one column 
using the UPDATE statement. Suppose, the guardian 
(Table 8.6) with GUID 466444444666 has requested to 
change the Address to 'WZ - 68, Azad Avenue, Bijnour, 
MP' and Phone number to '9010810547'. 


mysql > UPDATE GUARDI AN 
-> SET GAddress = 'WZ - 68, Azad Avenue, 
-> Bijnour, MP', GPhone = 9010810547 
-> WHERE GUID = 466444444666; 
Query OK, 1 row affected (0.06 sec) 
Rows matched: 1 Changed: 1 Warnings: 0 
mysql> SELECT * FROM GUARDIAN ; 


| | 

t-- +e - eee eee tes eee eee eee eee t-- +e eee tee ee ee eee eee + 
1}444444444444| Amit Ahuja 15711492685] G-35, Ashok vihar, Delhi | 
} 112111111111] Baichung Bhutia|] 7110047139] Flat no. 5, Darjeeling Appt., Shimla] 
|} 101010101010] Hi manshu Shah |9818184855| 26/77, West Patel Nagar, Ahmedabad | 
| 333333333333] Danny Dsouza | NULL |S -13, Ashok Village, Daman | 
1466444444666] Sujata P. |9010810547| WZ - 68, Azad Avenue, Bijnour, MP | 
tee eee eee eee tes ee eee eee eee t-- +2 - eee tee ee eee ee eee eee + 
5 rows in set (0.00 sec) 


8.7.2 Data Deletion 


The DELETE statement is used to delete one or more 
record(s) from a table. 


Syntax: 
DELETE FROM table name 
WHERE condition: 
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Suppose the student with roll number 2 has left the 
school. We can use the following MySQL statement to 
delete that record from the STUDENT table. 


mysql > DELETE FROM STUDENT WHERE Roll Number = 2; 
Query OK, 1 row affected (0.06 sec) 


mysql> SELECT * FROM STUDENT ; 
+ 


See eee en Cs 
| Roll Number | SName | SDateofBirth | GUID | 
te +--+ eee eee tee - eee eee ee eee tee eee ee ee ee eee t-- +e eee ee ee eee + 
| 1 | Atharv Ahuja | 2003-05-15 | 444444444444 | 
| 3 | Taleem Shah | 2002-02-28 | 101010101010 | 
| 4 | John Dsouza | 2003-08-18 | 325393953339 | 
| 5 | Ali Shah | 2003-07-05 | 101010101010 | 
| 6 | Manika P. | 2002-03-10 | 466444444666 | 
te - +e eee ee eee tee eee eee eee eee tee eee eee eee eee t-- ++ eee eee eee + 


5 rows in set (0.00 sec) 


Caution: Like UPDATE statement, we need to be careful to include 
WHERE clause while using DELETE statement to delete records in a 
table. Otherwise, all the records in the table will get deleted. 


Database is a collection of related tables. MySQLisa 
‘relational’ DBMS. A table is a collection of rows and 
columns, where each row is a record and columns 
describe the feature of records. 


SOL is the standard language for most RDBMS. 
SOL is case insensitive. 


CREATE DATABASE statement is used to create a new 
database. 


USE statement is used for making the specified 
database as active database. 


CREATE TABLE statement is used to create a table. 


Every attribute in a CREATE TABLE statement must 
have a name and a datatype. 


ALTER TABLE statement is used to make changes in 
the structure of a table like adding, removing or 
changing datatype of column(s). 


The DESC statement with table name shows the 
structure of the table. 


INSERT I NTO statement is used to insert record(s) in 
a table. 


UPDATE statement is used to modify existing data in 
a table. 


DELETE statement is used to delete records in a table. 
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Exercise ZEA 4H 
1. Match the following clauses with their respective 





= a aa INTRODUCTION TO STRUCTURED QUERY LANGUAGE (SQL) 


The SELECT statement is used to retrieve data from 
one or more database tables. 

SELECT * FROM table_name displays data from all 
the attributes of that table. 


The WHERE clause is used to enforce condition(s) in 
a query. 

DI STI NCT clause is used to eliminate repetition and 
display the values only once. 


The BETWEEN operator defines the range of values 
inclusive of boundary values. 


The | N operator selects values that match any value 


in the given list of values. 


NULL values can be tested using |S NULL and IS 
NOT NULL. 


ORDER BY clause is used to display the result of an 
SQL query in ascending or descending order with 
respect to specified attribute values. The default is 
ascending order. 


LI KE clause is used for pattern matching. % and _ 
are two wild card characters. The percent (%) symbol 
is used to represent zero or more characters. The 
underscore (_) symbol is used to represent a single 
character. 





functions. 
ALTER Insert the values in a table 
UPDATE Restrictions on columns 
DELETE Table definition 
INSERT INTO Change the name of a column 
CONSTRAINTS Update existing information in a table 
DESC Delete an existing row from a table 


459 27. Y MD Create a database 


Choose appropriate answer with respect to the following 


code snippet. 
CREATE TABLE student ( 
name CHAR( 30), 
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NOTES student_id INT, 
gender CHAR(1), 


PRIMARY KEY (student_ 1d) 


ie 


a) What will be the degree of student table? 
i) 30 
ii) 1 
iii) 3 
iv) 4 
b) What does ‘name’ represent in the above code snippet? 
i) atable 
li) a row 
iii) a column 
iv) a database 


c) What is true about the following SQL statement? 
SelecT * f ROM student; 


i) Displays contents of table ‘student’ 
ii) Displays column names and contents of table 
‘student’ 
iii) Results in error as improper case has been used 
iv) Displays only the column names of table ‘student’ 


d) What will be the output of following query? 
INSERT | NTO student 


VALUES (“Suhana”,109,'F'), 
VALUES (“Rivaan”,102,'M’'), 
VALUES (“Atharv"”,103,'M'), 


( 
(' 

VARUES @NAyshika”’,105,'F’), 
[' 
(' 


VALUES (“Garvit",104,'M’), 
VALUES (“Shaurya”,109,'M'): 
i) Error 


ii) No Error 

iii) Depends on compiler 

iv) Successful completion of the query 

e) In the following query how many rows will be deleted? 
DELETE student 
WHERE student _1d=109; 
i) 1 row 

ii) All the rows where student ID is equal to 109 

iii) No row will be deleted 

iv) 2 rows 


3. Fill in the blanks: 

a) declares that an index in one table is 

related to that in another table. 
i) Primary Key 

ii) Foreign Key 
iii) Composite Key 
iv) Secondary Key 

b) The symbol Asterisk (*) in a select query retrieves 


i) All data from the table 
ii) Data of primary key only 
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iii) NULL data 
iv) None of the mentioned 


4. Consider the following MOVIE database and answer the 
SQL queries based on it. 


Hindi_Movie Musical 2018-04-23 

002 Tamil Movie Action 2016-05-17 

003 English_Movie Horror 2017-08-06 

004 Bengali_Movie Adventure 2017-01-04 

005 Telugu_Movie Action - 

006 Punjabi_Movie Comedy - 

a) Retrieve movies information without mentioning their 
column names. 

b) List business done by the movies showing only 
MovieID, MovieName and BusinessCost. 

c) List the different categories of movies. 

d) Find the net profit of each movie showing its ID, Name 
and Net Profit. 

(Hint: Net Profit = BusinessCost — ProductionCost) 

Make sure that the new column name is labelled as 
NetProfit. Is this column now a part of the MOVIE 
relation. If no, then what name is coined for such 
columns? What can you say about the profit of a 
movie which has not yet released? Does your query 
result show profit as zero? 

e) List all movies with ProductionCost greater than 
80,000 and less than 1,25,000 showing ID, Name 
and ProductionCost. 

f) List all movies which fall in the category of Comedy 
or Action. 

g) List the movies which have not been released yet. 


5. Suppose your school management has decided to conduct 
cricket matches between students of class XI and Class 
XII. Students of each class are asked to join any one 
of the four teams — Team Titan, Team Rockers, Team 
Magnet and Team Hurricane. During summer vacations, 
various matches will be conducted between these teams. 
Help your sports teacher to do the following: 


a) 
b) 


Create a database “Sports”. 
Create a table “TEAM” with following considerations: 


i) It should have a column TeamID for storing an 
integer value between 1 to 9, which refers to 
unique identification of a team. 

ii) Each TeamID should have its associated name 
(TeamName), which should be a string of length 
not less than 10 characters. 
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c) Using table level constraint, make TeamID as primary 
key. 


d) Show the structure of the table TEAM using SQL 
command. 


e) As per the preferences of the students four teams 
were formed as given below. Insert these four rows in 
TEAM table: 

Row 1: (1, Team Titan) 
Row 2: (2, Team Rockers) 
Row 3: (3, Team Magnet) 
Row 4: (4, Team Hurricane) 
f) Show the contents of the table TEAM. 
g) Now create another table below. MATCH_DETAILS 


and insert data as shown in table. Choose appropriate 
domains and constraints for each attribute. 


Table: MATCH_DETAILS 


| MatchID | MatchDate | FirstTeamID | SecondTeamID | FirstTeamScore | SecondTeamScore 
M1 1 2 90 86 


2018-07-17 
M2 2018-07-18 3 4 49 48 
M3 2018-07-19 1 3 T8 56 
M4 2018-07-19 2 g 56 67 
M5 2018-07-20 1 4 32 87 
M6 2018-07-21 2 3 67 51 


h) Use the foreign key constraint in the MATCH_ 
DETAILS table with reference to TEAM table so 
that MATCH_DETAILS table records score of teams 
existing in the TEAM table only. 


6. Using the sports database containing two relations 
(TEAM, MATCH_DETAILS), answer the following 
relational algebra queries. 


a) Retrieve the MatchID of all those matches where both 
the teams have scored > 70. 


b) Retrieve the MatchID of all those matches where 
FirstTeam has scored < 70 but SecondTeam has 
scored > 70. 


c) Find out the MatchID and date of matches played by 
Team 1 and won by it. 


d) Find out the MatchID of matches played by Team 2 
and not won by it. 

e) In the TEAM relation, change the name of the relation 
to T_DATA. Also change the attributes TeamID and 
TeamName to T_ID and T_NAME respectively. 


7. Differentiate between the following commands: 
a) ALTER and UPDATE 
b) DELETE and DROP 
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8. Create a database called STUDENT_PROJECT having 
the following tables. Choose appropriate data type and 
apply necessary constraints. 


Table: STUDENT 





_RollNo | Name | stream | o Section | RegistrationID 


* The values in Stream column can be either Science, Commerce, 
or Humanities. 
* The values in Section column can be either I or II. 


Table: PROJECT ASSIGNED 


RegistrationID ProjectID AssignDate 


Table: PROJECT 


ProjectID ProjectName SubmissionDate GuideTeacher 


a) Populate these tables with appropriate data. 


b) Write SQL queries for the following. 

c) Find the names of students in Science Stream. 

d) What will be the primary keys of the three tables? 
e) What are the foreign keys of the three relations? 


f) Finds names of all the students studying in class 
‘Commerce stream’ and are guided by same teacher, 
even if they are assigned different projects. 


9. An organization ABC maintains a database EMP- 
DEPENDENT to record the following details about its 
employees and their dependents. 

EMPLOYEE(AadhaarNo, Name, Address, Department, 
Emp! D) 
DEPENDENT(Emp!ID, Dependent Name, Relationship) 
Use theEMP- DEPENDENT database to answer the following 
SQL queries: 
a) Find the names of employees with their dependent 
names. 


b) Find employee details working in a department, say, 
‘PRODUCTION’. 


c) Find employee names having no dependent 


d) Find names of employees working in a department, 
say, SALES’ and having exactly two dependents. 


10. A shop called Wonderful Garments that sells school 
uniforms maintain adatabaseSChOOL UNI FORM as shown 
below. It consisted of two relations — UNIFORM and 
PRICE. They made UniformCode as the primary key for 
UNIFORM relation. Further, they used UniformCode and 
Size as composite keys for PRICE relation. By analysing 
the database schema and database state, specify SQL 
queries to rectify the following anomalies. 
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UNIFORM 


il 


nO a A OD 


Shirt 
Pant 
Skirt 
Tie 
Socks 
Belt 
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a) The PRICE relation has an attribute named Price. In 
order to avoid confusion, write SQL query to change 
the name of the relation PRICE to COST. 


PRICE 


Mucede | size | Price 
1 M 500 


White 

Grey 1 L 580 

Grey 1 XL 620 

Blue 2 810 

Se 2 i 890 

Blue 2 XL 940 
3 M TTO 
3 IL, 830 
3 XL 910 
4 S 150 
4 L 170 
5 S 180 
5 E 210 
6 M 110 
6 JE, 140 
6 XL 160 

M/S Wonderful Garments also keeps handkerchiefs 


b) 


c) 


d) 


of red color, medium size of 7100 each. Insert this 
record in COST table. 


When you used the above query to insert data, 
you were able to enter the values for handkerchief 
without entering its details in the UNIFORM 
relation. Make a provision so that the data can be 
entered in COST table only if it is already there in 
UNIFROM table. 


Further, you should be able to assign a new UCode 
to an item only if it has a valid UName. Write a 
query to add appropriate constraint to the SCHOOL_ 
UNIFORM database. 


ALTER table to add the constraint that price of an 
item is always greater than zero. 
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